home
***
CD-ROM
|
disk
|
FTP
|
other
***
search
/
Chip 2011 November
/
CHIP_2011_11.iso
/
Programy
/
Inne
/
Gry
/
Carnage_Contest
/
scripts
/
CC Original
/
weapons
/
Diabolic Grenade.lua
< prev
next >
Wrap
Text File
|
2010-08-31
|
7KB
|
177 lines
--------------------------------------------------------------------------------
-- Weapon Diabolic Grenade + Projectile Diabolic Grenade
-- Original Carnage Contest Weapon
-- Script by DC, September 2009, www.UnrealSoftware.de
--------------------------------------------------------------------------------
-- Setup Tables
if cc==nil then cc={} end
cc.diabolicgrenade={}
cc.diabolicgrenade.diabolicgrenade={}
-- Load & Prepare Ressources
cc.diabolicgrenade.gfx_wpn=loadgfx("weapons/diabolicgrenade.bmp") -- Weapon Image
setmidhandle(cc.diabolicgrenade.gfx_wpn)
cc.diabolicgrenade.sfx_attack=loadsfx("diaboliclaugh.ogg") -- Attack Sound
cc.diabolicgrenade.sfx_bounce=loadsfx("bounce.wav") -- Bounce Sound
--------------------------------------------------------------------------------
-- Weapon: Diabolic Grenade
--------------------------------------------------------------------------------
cc.diabolicgrenade.id=addweapon("cc.diabolicgrenade","Diabolic Grenade",cc.diabolicgrenade.gfx_wpn,0,2) -- Add Weapon (0 uses, first in round 2)
function cc.diabolicgrenade.draw() -- Draw
if weapon_shots<=0 then
setblend(blend_alpha)
setalpha(1)
setcolor(255,255,255)
drawinhand(cc.diabolicgrenade.gfx_wpn,6,0)
end
-- HUD chargebar
if weapon_charge>0 and weapon_shots==0 then
hudchargebar(weapon_charge,100)
end
-- HUD Crosshair / HUD Timer
if weapon_shots==0 then
hudcrosshair(4,3)
hudtimer(3,1,10)
end
end
function cc.diabolicgrenade.attack(attack) -- Attack
if (weapon_shots<=0) then
-- Charge
if (attack==1) then
weapon_charge=weapon_charge+1 -- Increase charge
end
-- Fire a projectile (on release/full charge)
if (attack==0 and weapon_charge>0) or (weapon_charge>=100) then
-- No more weapon switching!
useweapon(0)
playsound(cc.diabolicgrenade.sfx_attack)
weapon_shots=weapon_shots+1
id=createprojectile(cc.diabolicgrenade.diabolicgrenade.id)
projectiles[id]={}
-- Ignore collision with current player at beginning
projectiles[id].ignore=playercurrent()
-- Set initial position of projectile
projectiles[id].x=getplayerx(0)+(4*getplayerdirection(0))
projectiles[id].y=getplayery(0)+3
-- Initial collision check (avoid throwing into other objects)
for i=0,10,1 do
if collision(col5x5,projectiles[id].x+math.sin(math.rad(getplayerrotation(0)))*i,projectiles[id].y-math.cos(math.rad(getplayerrotation(0)))*i)==1 then
if terraincollision()==1 or objectcollision()>0 or playercollision()~=projectiles[id].ignore then
if (i==0) then
projectiles[id].x=getplayerx(0)
projectiles[id].y=getplayery(0)+3
break
else
projectiles[id].x=getplayerx(0)+(4*getplayerdirection(0))+math.sin(math.rad(getplayerrotation(0)))*(i-1)
projectiles[id].y=getplayery(0)+3-math.cos(math.rad(getplayerrotation(0)))*(i-1)
break
end
end
end
end
-- Set speed of projectile
projectiles[id].sx=math.sin(math.rad(getplayerrotation(0)))*(weapon_charge/100.0)*10.0
projectiles[id].sy=-math.cos(math.rad(getplayerrotation(0)))*(weapon_charge/100.0)*10.0
-- Set timer
projectiles[id].timer=weapon_timer*50
-- Effects
recoil(2)
-- End Turn
endturn()
end
end
end
--------------------------------------------------------------------------------
-- Projectile: Diabolic Grenade
--------------------------------------------------------------------------------
cc.diabolicgrenade.diabolicgrenade.id=addprojectile("cc.diabolicgrenade.diabolicgrenade") -- Add Projectile
function cc.diabolicgrenade.diabolicgrenade.draw(id) -- Draw
-- Setup draw mode
setblend(blend_alpha)
setalpha(1)
setcolor(255,255,255)
setscale(1,1)
-- Calculate projectile rotation
setrotation(math.deg(math.atan2(projectiles[id].sx,-projectiles[id].sy)))
-- Draw projectile
drawimage(cc.diabolicgrenade.gfx_wpn,projectiles[id].x,projectiles[id].y)
-- Draw Arrow if out of Screen
outofscreenarrow(projectiles[id].x,projectiles[id].y)
end
function cc.diabolicgrenade.diabolicgrenade.update(id) -- Update
-- Particle Tail
particle(p_lightpuff,projectiles[id].x,projectiles[id].y)
particlespeed(math.random(-4,4)*0.1,math.random(-4,4)*0.1)
particlecolor(255,math.random(0,100),0)
-- Gravity influence on speed
projectiles[id].sy=projectiles[id].sy+getgravity()
-- Move (in substep loop for optimal collision precision)
msubt=math.ceil(math.max(math.abs(projectiles[id].sx),math.abs(projectiles[id].sy))/3)
msubx=projectiles[id].sx/msubt
msuby=projectiles[id].sy/msubt
for i=1,msubt,1 do
-- Move X
projectiles[id].x=projectiles[id].x+msubx
if collision(col5x5,projectiles[id].x,projectiles[id].y)==1 then
if terraincollision()==1 or objectcollision()>0 or playercollision()~=projectiles[id].ignore then
if (math.abs(projectiles[id].sx)>0.5) then playsound(cc.diabolicgrenade.sfx_bounce) end
projectiles[id].x=projectiles[id].x-msubx
projectiles[id].sx=-projectiles[id].sx*0.3
msubx=-msubx*0.3
end
else
projectiles[id].ignore=0
end
-- Move Y
projectiles[id].y=projectiles[id].y+msuby
if collision(col5x5,projectiles[id].x,projectiles[id].y)==1 then
if terraincollision()==1 or objectcollision()>0 or playercollision()~=projectiles[id].ignore then
if (math.abs(projectiles[id].sy)>0.5) then playsound(cc.diabolicgrenade.sfx_bounce) end
projectiles[id].y=projectiles[id].y-msuby
projectiles[id].sy=-projectiles[id].sy*0.3
msuby=-msuby*0.3
projectiles[id].sx=projectiles[id].sx*0.9
msubx=msubx*0.9
end
else
projectiles[id].ignore=0
end
-- Water
if (projectiles[id].y)>getwatery()+5 then
-- Effects
particle(p_waterhit,projectiles[id].x,projectiles[id].y)
playsound(sfx_hitwater1)
-- Free projectile
freeprojectile(id)
break
end
end
-- Timer -> Explode
projectiles[id].timer=projectiles[id].timer-1
if projectiles[id].timer<=0 then
-- Cause damage
arealdamage(projectiles[id].x,projectiles[id].y,200,95)
-- Destroy terrain
terrainexplosion(projectiles[id].x,projectiles[id].y,60,1)
-- Crater
grey=math.random(0,20)
if math.random(0,1)==1 then
terrainalphaimage(gfx_crater175,projectiles[id].x,projectiles[id].y,math.random(7,9)*0.1,grey,grey,grey)
else
terrainalphaimage(gfx_crater200,projectiles[id].x,projectiles[id].y,math.random(7,9)*0.1,grey,grey,grey)
end
-- Free projectile
freeprojectile(id)
end
-- Scroll to projectile
scroll(projectiles[id].x,projectiles[id].y)
end